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INCREASED RELIABILITY OF DATA STORED ON FLASH MEMORY IN 
APPLICATIONS SENSITIVE TO POWER-LOSS 

CROSS-REFERENCED RELATED APPLICATION 

5 This application is Continuation-in-Part of U.S. Patent Application No. 

09/063,954 entitled, "DYNAMIC ALLOCATION FOR EFFICIENT MANAGEMENT 
OF VARIABLE SIZED DATA WITHIN A NONVOLATILE MEMORY," filed on April 
21, 1998. 

10 FIELD OF THE INVENTION 

The present relates to computer memory storage systems. More particularly, the 
present invention relates to dynamic allocation for efficient management of variable sized 
data within a nonvolatile memory. Specifically, the present relates to increased reliability 
of data stored on flash memory in applications sensitive to power-loss. 

15 

BACKGROUND OF THE INVENTION 

Communications devices such as cellular telephones and pagers need the ability to 
store both data and code. In addition, these communications devices typically require 
some sort of working memory. 

10 These communication devices generally need to store the code and at least some 

of the data in nonvolatile memory. For example, serial numbers, authorization codes, 
frequently dialed numbers, etc. are examples of data that might be stored in nonvolatile 
memory. Given that the code and data are updated at different frequencies, the 
communications devices often used different types of nonvolatile memory for storage of 

15 data and code. As a result, prior art communications devices typically included one type 
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of nonvolatile memory for code storage, another nonvolatile memory for data storage, and 
random access memory such as static random access memory for working memory. 

One type of nonvolatile memory is a flash electrically erasable programmable read 
only memory (flash EEPROM). Flash EEPROM (hereinafter "flash memory") is 
5 typically arranged as blocks of single transistor memory cells. Although flash memory is 
rewritable, the memory cells cannot be re-programmed unless they have first been erased. 
Moreover, the cells are erasable only in blocks. Thus in order to erase one cell, an entire 
block of cells must be erased. Updating the flash memory requires some form of media 
manager to handle copying of valid information out of the block, erasing the block, and 

10 writing the valid information as well as the update information to the same or another 
block. The process of erasing, writing, etc. is relatively time consuming. 

Another type of nonvolatile memory is an electrically erasable programmable read 
only memory (EEPROM) having two-transistor memory cells. Although EEPROM may 
be arranged into erasable blocks similar to the flash memory, the two-transistor EEPROM 

15 is relatively easy to update and does not require the sophisticated media management that 
flash memory requires for updates. Writing a value to the two-transistor EEPROM cell, 
however, requires significantly greater time than does programming of an erased single 
transistor flash memory cell. 

One prior art communications device memory architecture includes flash memory 

20 for code storage, EEPROM for data storage, and random access memory as working 
memory. 

The use of a variety of nonvolatile memories tends to increase form factor size as 
well as design and fabrication costs. Personal communications devices such as pagers 
and cellular telephones are often differentiated based on their size, features, cost, and rate 
25 of power consumption. 
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Moreover as new features are constantly being added, the ratio of code to data 
may need to change. Providing excess storage for both types of nonvolatile memory 
increases the cost of the device and is wasteful, unless the storage requirements for both 
the code and the data are expected to grow. By storing code and data into different types 
5 of nonvolatile memory, excess storage capacity in the nonvolatile memory used for code 
is unavailable for storing data. Similarly, excess storage capacity in the nonvolatile 
memory used for data is unavailable for storing code. Thus the design is unable to easily 
accommodate changes in the ratio of nonvolatile memory allocated to code versus that 
allocated to data. 

0 Furthermore, a common concern with operating a nonvolatile memory device 

such as a flash memory is power-loss. That is, a sudden loss of power may cause data in 
the non-volatile memory to be lost or unreliable. Thus, a nonvolatile memory device 
must be able to recover and to determine the reliability of data in the memory device after 
a power-loss. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

The present invention is illustrated by way of example and not intended to be 
limited by the figures of the accompanying drawings, in which like references indicate 
similar elements and in which: 
5 Figure 1 illustrates storage of code and data in the same monolithic nonvolatile 

memory device; 

Figure 2 illustrates the storage of objects within a block of the nonvolatile 
memory; 

Figure 3 illustrates an object header structure; 
10 Figure 4 illustrates a multiple instance storage structure; 

Figure 5 illustrates a sequence table entry and status values; 
Figure 6 illustrates the use of a sequence table for identifying the order and 
location of associated data fragments; 

Figure 7 illustrates the use of a group table for identifying the order and location 
15 of associated sequence table fragments; 

Figure 8 illustrates a method of creating the data lookup table; 
Figure 9 illustrates a method of selecting a storage structure in accordance with 
the size (z) of the data with respect to a plurality of thresholds including: a minimum 
number of instances (m); an allocation granularity (g); a maximum single instance size 
20 {s*g)\ and a maximum sequence table size; 

Figure 10 illustrates a method of writing a single instance object; 
Figures 11-12 illustrate a method of writing a multiple instance object; 
Figures 13-15 illustrate a method of storing an object as a plurality of data 
fragments; 
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Figure 16 illustrates a method for appending to a fragmented object when 
sufficient room is available in the last sequence table fragment; 

Figures 17-19 illustrates a method for replacing selected fragments of a 
fragmented object; 

5 Figure 20 illustrates a method for reclaiming space within the nonvolatile 

memory; 

Figure 21 illustrates a flash memory system; 

Figure 22 illustrates a timing diagram for a flash memory system causing storage 
of invalid data; 

10 Figure 23 illustrates a new data header having redundant power-loss status fields 

to deal with power-loss; and 

Figure 24 illustrates a method for duplicating power-loss status fields. 



5 



DETAILED DESCRIPTION 

Figure 1 illustrates the storage of both code and data in a monolithic nonvolatile 
memory device 1 10. In one embodiment, the nonvolatile memory comprises a plurality 
of individually erasable blocks. The amount of space allocated to the data and code 
5 portions may span one or more blocks as long as the data and code portion do not share a 
same block. 

Nonvolatile memory device 1 10 has a boot code 112 portion, a data storage 1 14 
portion, a spare block 116, and a code storage 118 portion. The spare block 116 is an 
actual physical block of the nonvolatile memory device. As will be described below, 

10 logical block numbers are used so that the spare block can be any physical block within 
the data portion 1 14. 

Spare block 116 is used during the reclamation process to recover the valid 
contents of another block before erasing that other block to free up the space used by 
invalid contents. Due to the characteristics of flash memory and the relatively long time 

15 required to erase a block, superseding data is written to a new location within the 

nonvolatile memory. The older version of the data is invalidated and the space associated 
with the invalid data can subsequently be reclaimed by erasing the block after copying 
any valid data in the block to the spare block. After erasure, the erased block becomes 
the new spare block. 

20 Figure 2 indicates how data is identified and stored within one of the individual 

blocks allocated to the data storage 1 14 portion of Figure 1. The minimal amount of 
space that can be allocated is referred to as the unit granularity, or simply granularity. 
The data to be stored is allocated into individual areas spanning one or more units of 
granularity. Each of these areas is referred to as an object. For example, block 210 

25 includes objects 1, 2, and 3. Each object within the block is identified by an object 
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header. Thus for example, header 1 (212) identifies object 1 (222); header 2 (214) 
identifies object 2 (224); and header 3 (216) identifies object 3 (226). 

The headers are written to a selected block proceeding contiguously from a first 
end of the block to a second end of the block. The object associated with each header is 
5 written to the block proceeding contiguously from the second end towards the first end of 
the block. Thus the headers and objects "grow" towards each other as additional objects 
and headers are stored in the block 210. 

Each block 210 also has a block information structure 240, The block 
information structure 240 maintains a logical block number 244 and tracks the 
10 reclamation status 242 for block 210. The use of a logical block number permits 

information to be stored logically contiguously without actual physical block contiguity. 

During reclamation, the valid contents of a block scheduled for reclamation must 
be copied to another block before the block scheduled for reclamation can be erased. In 
one embodiment, the block information structure includes physical copy 246 to indicate 
15 the physical block being copied from during a reclamation. This is useful for recovery 
procedures if the copying were interrupted, for example, by a power failure. In addition, 
the physical copy 246 field aids in identifying any blocks that may have been in the 
process of being erased in the event that the erase operation was interrupted, for example, 
by a power failure. 

20 The block information structure 240 also includes an integrity field 248. The 

integrity field is used to ensure the integrity of the block information structure 210 itself. 

Figure 3 illustrates one embodiment of the header data structure 300. The header 
data structure includes identifier 302, status 304, type 306, size 308, and offset 310 fields. 
The identifier 302 field identifies the associated object. For example, the identifier might 

25 be a name or a number for the data (e.g., parameter "X" or "5631")- 
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The status 304 field is used to track the status of the header and object. The status 
of the header and the object is used when building the RAM lookup table as discussed 
below as well as when performing power loss recovery. Table 320 indicates one 
embodiment of a state assignment for the status fields. 

Size 308 indicates the size of the object in multiples of allocation units. Thus if 
the minimum allocation unit (i.e., granularity) is 4 Kb, a size of 8 indicates that the object 
is 32 Kb in size. 

Offset 310 is used to identify the location of the object within the block. In one 
embodiment, offset 310 is a pointer indicating the offset of the object as measured from 
the bottom of the block in granular units. 

Type 306 is used to indicate the object's type and structure. Li one embodiment, a 
first portion of type 306 is used to identify pre-determined object structures. A second 
portion of type 306 identifies the contents of the pre-determined object structure (i.e., the 
type of data stored within that structure). The pre-determined object structures are 
designed to accommodate a range of object sizes as well as variations in expected 
volatility of the object. 

The types of data are generally specific to the application. In one embodiment, 
the nonvolatile memory device supports wireless communication devices such as a 
cellular telephone or pager. Examples of types of data for communications applications 
include data parameters (e.g., for tracking origin, destination, and length of 
communication), data streams, telephone numbers, facsimile numbers, etc., or other 
user-definable types. 

Table Number 312 is used to associate fragmented data with tables used to track 
the location of the fragmented data. The use of Table Number 312 is used to minimize 
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the amount of updating that must take place when changes are made to a fragmented 
object as will be described below. 

In one embodiment, the pre-determined object structures include: multiple 
instance object, single instance object, data fragment, sequence table, sequence table 
fragment, and group table. 

A single instance object can fit entirely within a block. A single instance object is 
allocated in multiples of the allocation granularity. A single instance object is not 
permitted to span blocks. In order to retrieve data stored as a single instance object 
requires merely examining the header to determine the location of the single instance 
object and then retrieving the single instance object itself. 

A multiple instance unit is designed to store relatively small sized data that can be 
updated several times using the same space originally allocated for storing the object. 
This is particularly useful for frequently updated data such as variables. 

Figure 4 illustrates the structure of multiple instance object 400. Providing for 
multiple instances within the same allocated space reduces the overhead in managing 
small data parameters and improves the performance of updates. 

The multiple instance object 400 includes instance information 410 to indicate the 
size of each instance and the number of instances within the multiple instance object. 
Following the instance information 410 are a plurality of status fields 422, 432, 442, and 
452. Each status field is associated with one instance of the object. Thus, for example, 
status 422 applies to instance 420. Status 432 applies to instance 430, 442 applies to 440, 
and 452 applies to 450. One embodiment for the state assignments for the various status 
conditions is set forth in table 460. 

Another object structure is the data fragment. Some objects must be fragmented 
in order to be stored within the available space of a plurality of blocks. This may be 



necessary, for example, if the object is larger than the block. Alternatively, fragmentation 
may be necessary if the object is larger than the space remaining within a given block. 
Thus any data spanning physical block boundaries will be fragmented into multiple data 
fragments. Each of these fragments is referred to as a data fragment object. The data 
5 fragment object contains a fragment of the original data, but no other overhead 

information, A sequence table containing an ordered list of data fragments is used to 
reassemble the original data from a plurality of data fragments. 

Figure 5 illustrates the structure for each entry of a sequence table fragment and 
status values for each entry. The entry includes a field for the logical block number 

10 (512), entry status (514), instance (516), data fragment size (518), the size of an older 
version of the data fragment if applicable (520), and a physical index (522). The status 
values used for entry status are illustrated in table 560. The instance value is used to 
identify a particular data fragments when an object has more than one data fragment 
stored in the same block. 

15 Figure 6 illustrates a sequence table 616 as well as the process for assembling all 

the data fragments associated with the sequence table. Thus for example, parameter X 
has been fragmented into a plurality of data fragments 614, 626, and 628 which are 
located in physical blocks 610 and 620. The corresponding headers 612, 622, and 624 
have their respective Table Number (312) fields set to identify sequence table 616. 

20 Sequence table 616 lists the logical block number and data fragment instance used 

to reassemble the complete parameter X. Multiple parameter X data fragments within the 
same block are distinguished by their instance or occurrence within that block as well as a 
particular sequence table they are associated with. The order of the entries in the 
sequence table indicates the order in which the data fragments must be assembled in order 

25 to form the complete parameter X. 
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For example, in order to reassemble the parameter X object, a search is conducted 
for the parameter X sequence table header (indicated in step ©). In one embodiment, the 
location of the parameter X sequence table header is stored in a data lookup table in order 
to speed retrieval of the parameter. In this case the data lookup table indicates that 
parameter X sequence table header is located in logical block 0 (610). 

Logical block 0 is scanned to locate the parameter X sequence table header. The 
parameter X sequence table header identifies the location of parameter X sequence table 
616 (as indicated by step ©). Each entry of sequence table 616 identifies the logical 
block and instance of a data fragment associated with that sequence table needed to 
reconstruct parameter X. 

Sequence table 616 indicates that the first data fragment is the first instance of a 
parameter X data fragment associated with sequence table 616 located in logical block 0. 
Thus the first data fragment is located by searching for the first header identifying a 
parameter X data fragment with a Table Number of 616 in logical block 0 (610) (as 
indicated by step ®). In this case the first header identifying a parameter X data fragment 
associated with sequence table 616 in logical block 0 is header 612. Header 612 is then 
used to locate parameter X data fragment 614 (as indicated by step ©). 

Referring to sequence table 616, the next parameter X data fragment is determined 
to be the second parameter X data fragment in logical block 1. Thus logical block 1 can 
be searched to locate the second occurrence of a parameter X data fragment header (as 
indicated by step ®). Header 624 identifies the location of parameter X data fragment 
626 as indicated by step ©. 

The final parameter X data fragment is determined to be the first parameter X data 
fragment in logical block 1 (620). Thus logical block 1 is searched to locate the first 
occurrence of a parameter X data fragment header. In this example, the first occurrence 
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of a parameter X data fragment header is header 622 as indicated by step ® . Parameter X 
data fragment header 622 identifies the location of the third and final parameter X data 
fragment 628 as indicated in step ©. 

If the parameter has a large number of data fragments, the sequence table may 
need to span physical block boundaries. Alternatively, the number of data fragments may 
require a sequence table size that exceeds a pre-determined threshold. Rather than 
attempt to maintain contiguity across multiple logical or physical blocks or permitting the 
sequence table to grow beyond the pre-determined threshold, another sequence table is 
created. In one embodiment, this pre-determined threshold is the maximum size 
permitted for a single instance object. As the size of the sequence table grows, so does 
the amount of time required to copy the sequence tables when updating blocks. 

A group table is used to track individual sequence tables much the same way as 
sequence tables are used to track data fragments. The use of group tables and multiple 
sequence tables also tends to reduce the time required to manage copying of sequence 
tables. The group table effectively fragments a large sequence table into a plurality of 
smaller sequence tables fragments. When multiple sequence tables are used in 
conjunction with a group table, the individual sequence tables are identified as sequence 
table fragments. 

Figure 7 illustrates the use of a group table 716 in conjunction with sequence table 
fragments. Group table 716 is similar to the sequence table structure, however, the 
fragments identified are sequence tables fragments which themselves identify the location 
and order of data fragments associated with the object. Each entry of the group table 716 
thus indirectly identifies a group of data fragments. 

To retrieve parameter X, the parameter's group table header is first located. In 
this case, the parameter X group table header is found in logical block 0 (710). Group 
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table header 712 identifies group table 716. Each entry of group table 716 identifies the 
location and instance of a sequence table fragment. 

Group table 716 indicates that the first sequence table fragment is the first 
instance of a parameter X sequence table fragment located in logical block 0. This is 
5 located by searching for the first header identifying a parameter X sequence table 

fragment in logical block 0 (710). In this case, the first header identifying a parameter X 
sequence table fragment in logical block 0 is header 718. Header 718 can then be used to 
locate parameter X sequence fragment 714. 

Sequence table fragment 714 indicates that the first data fragment is the first 

10 instance of a parameter X data fragment associated with sequence table fragment 714 
located in logical block 1 (720). Thus logical block 720 is searched to locate the first 
instance of a parameter X data fragment header 724 that has a Table Number set to 
indicate sequence table 714. The located header indicates the location of parameter X 
data fragment 730. The second and third data fragments associated with sequence table 

15 714 are not shown. 

The second and third sequence table fragments indicated in group table 716 can 
similarly be located by finding the headers (726, 722) in the order indicated by the group 
table and then using the headers to locate the respective second (726) and third (732) 
sequence table fragments. The entries in a given sequence table refer only to data 

20 fragment instances having headers that identify the same given sequence table. Thus for 
example, a number of data fragments associated with different sequence tables can be 
located in the same block. When traversing a sequence table to re-assemble the object, 
however, instances other than those sharing the same sequence table fragment are 
ignored. 
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In one embodiment, a data lookup table is used to improve performance of 
accessing the nonvolatile memory device. When implemented in a computer system, a 
lookup table can facilitate accessing the data stored within the nonvolatile memory. The 
data lookup table is built in RAM during initialization of the computer system and 
5 updated as appropriate during write and erase operations. The data lookup table provides 
a pointer to a particular block and offset associated with a selected header for data having 
a specified identifier. 

In one embodiment, the data lookup table uses the identifier as an index to the 
data. In an alternative embodiment, the data lookup table uses both the identifier and the 
10 type as an index to the data. The latter embodiment permits using non-unique identifiers 
as long as the combination of identifier and type are unique. Moreover, the latter 
embodiment permits rapid searching based on the type of the data rather than the data's 
identifier. 

One embodiment of the process for building the data lookup table is illustrated in 
15 Figure 8. Initialization starts in step 810. The physical blocks are scanned for valid 
single instance headers, sequence table headers, multiple instance headers, and group 
table headers in step 820. Data fragments are ignored. Similarly, sequence table 
fragments are ignored. 

If a single instance header, sequence table header, multiple instance header, or 
20 group table header is found (step 830), then the logical block number as well as the type 
for the data associated with that header (e.g., logical block 0, parameter X) are stored in 
the lookup table in step 840. In one embodiment, the identifiers are numbers which 
correspond to a position within the lookup table rather than a value explicitly stored in the 
lookup table. As a result, the identifier is used to calculate an entry position in the lookup 
25 table. The logical block number and type for that identifier are then stored in the lookup 
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table at the calculated position. In another embodiment, the type is not stored in the data 
lookup table. Alternatively, the data lookup table may explicitly store the identifier, the 
logical block number, and the type for the data associated with that header. The scanning 
process continues until no more such headers are located, then the process is terminated 
5 in step 890. 

The data lookup table identifies the headers for group table objects, sequence table 
objects, multiple instance objects, and single instance objects. In order to retrieve 
parameter X, the data lookup table can be consulted initially rather than scanning the 
headers of every block in the nonvolatile memory. Individual data fragments and 

10 sequence table fragments are not catalogued in the lookup table. 

In order to facilitate rapid determination of the available space within the blocks a 
logical block table is maintained in RAM. The logical block table provides a 
logical-to-physical block translation map and is created during initialization. During 
initialization, each physical block is scanned to determine the amount of available space 

15 and the amount of invalid space (i.e., space used by invalid objects and headers). This 
information is collected for each block within the nonvolatile memory device and stored 
in a logical block status table in RAM. The logical block table can then be updated for 
subsequent operations to the nonvolatile memory device. 

In one embodiment, the storage structure for data being written is automatically 

20 selected. The minimum amount of space that can be allocated within the nonvolatile 

memory is referred to as the unit granularity. The block with the greatest available space 
is selected as a candidate for writing a new object. The selection of the storage structure 
for the data to be stored is based on the size (z) of the data with respect to a number of 
thresholds and the available space within the candidate block. 
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A multiple instance structure is selected if a pre-determined minimum number of 

multiple instances (m) with accompanying overhead can fit within one granular unit (g). 

As long as m*z + overhead • g, the multiple instance data structure can be selected. Thus 
_g -overhead^ t , . t 

jf s. > z , the multiple instance data structure will be selected. 

m 

5 In the embodiment illustrated in Figure 4, the overhead includes a 1 byte instance 

size, a 1 byte number of instances, and one-half byte for each instance. For g = 128 

bytes and m = 3, the multiple instance unit structure can be selected as long as z is less 

. g- overhead 128 -(1 + 1 + .5(3)) 124.5 4 , s ^ 

than or equal to - = — = = 41.5 bytes. Thus a 40 

m 3 3 

byte size data, for example, can be stored in a multiple instance structure. 

10 The number of instances in a multiple instance structure is not limited to m. Once 

the multiple instance structure is selected, the instance size 402 is z, and the number of 



instances 404 (k) is computed as a value less than or equal to int 



g - overhead 



, where 



z 

4 int" represents the integer function such that "int(x)" returns the integer component of jc. 
In this case, due to the status fields, the overhead is a function of the number of 



15 instances, k. As a result, k is computed as ind 



z + v j 



, where /represents the fixed 



portion of the overhead independent of the number of instances, and v represents the 
amount of overhead added for each instance. The fixed portion of the multiple instance 
overhead is 2 bytes and the per instance overhead is .5 bytes. Therefore, in this example, 
a 7 byte parameter may have up to 16 instances in a multiple instance structure. 
20 If ineligible for a multiple instance structure, the data can be stored as a single 

instance object as long as the maximum single instance size is not exceeded. In one 
embodiment, The maximum single instance size is expressed as a number of minimum 
allocation units. Thus if the unit granularity (g) is 128 bytes, a maximum single instance 
size (s) of 4 units/fragment indicates that the data must be fragmented if the size of the 
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data exceeds 512 bytes. The data must also be fragmented if the size of the data is less 
than the amount of available space (z) within the candidate block. If the data size (z) is 
less than 512 bytes then the data can be stored as a single instance unit as long as 
sufficient space is available. Expressed mathematically, the single instance object 
5 structure is selected as long as z • min(s*g, z), where min(a, b) = a if a ♦ b or b otherwise. 

If the size of the data is greater than the maximum single instance size, then the 
data must be fragmented. Where possible, the data fragments will be as large as the 
maximum single instance size. The data is stored using data fragments and a sequence 
table as long as the size of the resulting sequence table does not exceed a maximum 

10 sequence table size. Otherwise, the data is stored using data fragments, sequence table 
fragments, and a group table. 

In one embodiment, the determination as to which data structure is used is 
automated. Figure 9 illustrates the process for determining which object structure to use 
for initially storing data in the nonvolatile memory. A request to write data is received in 

15 step 910. Typically the nonvolatile memory will comprise a plurality of blocks. During 
use of the storage system, blocks may have differing amounts of available space. When 
storing a new data object, the block having the greatest amount of available space is 

selected in step 912. 

T r ^ granularity - overhead , . , . „ rt t , , . t 

If z <- - as determined m step 920, then the multiple 

min#of instances 

20 instance structure is selected as the storage structure in step 922. Otherwise processing 
continues with step 930. 

If z * maximum single instance size as determined in step 930, then the single 
instance structure is selected in step 932. A single instance structure is allocated the least 
integer number (s) of granular units (g) such that z * s*g • maximum single instance size. 
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If z exceeds the maximum single instance size, then the data must be fragmented. Step 
934 determines the number of fragments required for storing the data. 

If the number of fragments needed exceeds the maximum size for a sequence table 
as determined in step 940, then the data will be fragmented and stored using group tables 
5 and sequence table fragments as indicated in step 942. Otherwise, the data is stored using 
sequence tables as indicated in step 944. In an alternative embodiment, there are no 
individual sequence tables, thus group tables and sequence table fragments are used 
whenever z exceeds the maximum single instance size. In other words, as indicated by 
the dotted line 946, once step 930 determines that z > the maximum single instance size, 

10 processing continues with step 942 to store the data using group tables, sequence table 
fragments, and data fragments. 

The process of writing a single instance object is illustrated in Figure 10 
beginning with step 1010. In step 1020, the block with the greatest amount of available 
free space is located. In step 1030, a header for the object is written with the status of 

15 "allocating." After the header has been successfully written the status is changed to 
"header written" in step 1032. 

The process of writing the object is initiated in step 1040. If only a portion of the 
object is being written, the portion is treated as replacing the corresponding portion in a 
pre-existing version of the object. Any portions not being replaced must be the same as 

20 those in the pre-existing, valid version. Thus writing a new version of the object requires 
copying any portions of a pre-existing, valid version of the object that are not being 
replaced. The header status of the new version of the object is changed to "allocated" to 
indicate that the object has been written in step 1042. 
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Any pre-existing, "valid" version of the object is then invalidated in step 1050. 
In step 1060, the status for the object being written is changed to "valid." Finally, the 
data lookup table is updated in step 1070, 

The process of writing a multiple instance object is similar as illustrated in 
5 Figures 11-12 beginning with step 1 1 10. Step 1 1 12 determines whether there is a 

pre-existing multiple-instance object with the same identifier. If so, then the process may 
be able to utilize an available entry within the pre-existing multiple-instance object. 

If a pre-existing multiple instance object with the same name exists, processing 
continues with step 1 1 12. Step 1114 determines whether 1) z • the maximum amount of 
10 space available to each instance, and 2) if at least one entry is left for the object to be 

written. If both conditions are true, then this write operation can make use of an available 
multiple instance object entry. Otherwise, a new multiple instance object must be written 
in steps 1120-1132. 

The process of a new multiple instance object begins in step 1120 by searching for 
15 a block with enough space to store the multiple instance object. In an alternative 
embodiment, the block with the greatest amount of free space is selected. 

A multiple instance object header is written in step 1 122 with a status of 
"allocating." The status is changed in step 1 124 to indicate that the header was 
successfully written. Step 1 130 initiates writing the multiple instance data structure. 
20 In step 1 140 the first available entry in the multiple instance structure is selected 

for storing the multiple instance object. Referring to Figure 12, the status of the selected 
entry is changed to "allocating" in step 1210. Step 1220 initiates writing the object to the 
selected entry. The status of the selected entry is then changed to "valid" in step 1222. 
An instance of the object has now been stored. Step 1230 determines if the 
25 available entry was the first entry in the current multiple instance object structure. If not, 
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processing continues with step 1232 to invalidate the previous entry in the multiple 
instance object. The process of updating the multiple instance object is then completed ii 
step 1290. 

If the selected entry is the first entry in the multiple instance object, then 
additional steps are taken in 1240-1270 to invalidate pre-existing objects with the same 
identifier as well as validating the new multiple instance object. The multiple instance 
object status is changed to indicate a status of "allocated" in step 1240. Any pre-existing 
object with the same identifier is invalidated (status = "invalid") in step 1250. The status 
of the new multiple instance object is then changed to "valid" in step 1260. The creation 
of a new multiple instance object requires updating the lookup tables in step 1270. The 
process of storing a multiple instance object is then completed in step 1290. 

Figures 13-15 illustrate the process of writing an object as a plurality of data 
fragments when the size of the data to be written, z, exceeds the maximum size s*g 
allocable to any fragment. In one embodiment, s is the maximum single instance object 
size expressed as a multiple of the granularity. The process begins with step 1310. 

A block with sufficient free space is selected to write the group table to in step 
1320. In one embodiment, no object is permitted to exceed the maximum size, s*g, thus 
any block capable of storing an object of size s*g can be selected as the block for storing 
the group table. Li one embodiment, the block with the greatest amount of available free 
space is selected. 

In step 1322, a group table header is written with a status of "allocating." After 
writing the group table header, the status is changed to "header written" in step 1324. 

Step 1330 determines whether there is sufficient space in the current block to 
create a sequence table fragment. The current block is the same block that the group table 
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was created if this is the first sequence table fragment for the object. Otherwise, the 
current block is the block that the last data fragment was written to. 

If there is insufficient space in the current block, the block with the most available 
space is selected as the sequence table block for writing the next sequence table fragment 
5 to in step 1332. Otherwise, the current block is selected as the sequence table block for 
writing the next sequence table fragment to in step 1334. 

Once the sequence table block has been selected, a sequence table fragment 
header is written with a status of "allocating" in step 1340. After successfully writing the 
header, the status is changed to "header written" in step 1342. 
10 Figure 14 illustrates the process of writing each data fragment. In one 

embodiment, the data is stored by selecting fragments as large as possible until the object 
is completely stored. There are three possibilities: z m g,g<z 9 orz>s*g. 

Step 1410 selects a fragment of size k from the remaining data, where k is the 
lesser of 1) the maximum fragment size, s*g, or 2) the amount of data remaining to be 
15 stored, z.. 

Step 1420 determines whether there is sufficient space in the block that the last 
data fragment was written to. If the amount of data remaining to be stored is less than the 
minimum fragment size (e.g., one granular unit, g\ then the data fragment will still 
require one granular unit for storage even though z • g. l£g<z* s *g. then there must 
20 be at least j granular units available for storage where j is an integer such that z • ;*g • 
If z > then there must be sufficient space available to store a data fragment of 
size s*g. 

If so then the block the last data fragment was written to is selected for writing the 
next data fragment in step 1422. (If this is the first data fragment for a given object, then 
25 the block that the sequence table fragment is located in is considered to be the block that 
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the "last data fragment was written to.") Otherwise another block with sufficient space 
for writing the next data fragment is selected in step 1424. 

A data fragment header is written in step 1430 with a status of "allocating." The 
status is changed to "header written" in step 1432. Step 1440 initiates writing the data 
fragment. After the data fragment has been written, the status of the data fragment is 
changed to "allocated" in step 1442. The sequence table entry for the data fragment is 
then written with a status of "valid." Processing then continues with Figure 15. 

Referring to Figure 15, step 1510 determines whether any data remains to be 
stored. If so, processing continues with step 1520 to determine if another entry can be 
added to the current sequence table fragment. If the current sequence table fragment is 
not full, processing can continue with step 1410 of Figure 14 to continue fragmenting and 
storing the data. If there is no more room in the current sequence table fragment, then the 
current sequence table fragment header status is set to "allocated" in step 1570. The 
process then continues fragmenting and storing the data fragments after returning to step 
1330 of Figure 13 to create a new sequence table fragment. 

If no data remains to be stored in step 1510, the current sequence table fragment 
header status is changed to "allocated" in step 1530. At this point all the object's data 
fragments have been stored and can be located by the group table and sequence table 
fragments. Step 1532 changes the status of every data fragment associated with the 
object's group table to "valid." 

Any pre-existing "valid" version of the object then invalidated in step 1540. All 
sequence table fragments associated with the current version of the object have their 
status changed to "valid" in step 1542. The status of the group table for the current 
version of the object is then changed to "valid" in step 1550. The lookup tables (e.g., 
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data lookup table) are then updated in step 1560. The process of writing an object as a 
plurality of data fragments is then completed in step 1590. 

The process of invalidating a valid previous version of an object as set forth in 
step 1050 of Figure 10, step 1250 of Figure 12, and step 1540 of Figure 15 differs 
depending upon the object structure. To qualify as a valid previous version, the header of 
the object must have a status of "valid" and at least an identifier identical to that of the 
data being written. If the two versions of the object have different object structures, the 
preceding version must be invalidated in its entirety. 

Invalidating a multiple instance object or a single instance object merely requires 
changing the status for these objects to "invalid." Invalidating a fragmented object, 
however, requires invalidating each data fragment, each sequence table fragment entry, 
each sequence table fragment, and finally the group table. 

Creating and updating single instance objects and multiple instance objects 
generally requires replacing any previous version of the object. Thus for example, 
modifications to a single instance object will result in invalidating the previous version of 
the single instance object and writing a new object. Modifications to a multiple instance 
object will result in invalidating either a previous entry or even the previous multiple 
instance object structure in order to write a new version of the object. Thus modification 
of a single instance object or a selected instance of a multiple instance object typically 
results in the destruction of the previous version or instance of the object where 
appropriate. 

Modifications to a fragmented object may only affect a particular data fragment or 
only a few data fragments. Changes, however, must be cascaded to the affected sequence 
table fragments and the group table. Due to the characteristics of flash memory, 
however, the sequence table fragments and the group table cannot be modified in place. 



23 



One way to achieve this goal is to rewrite the object every time. Such a technique, 
however, would be inefficient if only a small amount of the data needed to be updated. 
The characteristics of flash memory tend to encourage updating as little as possible in 
order to avoid time consuming erasures and copying. In one embodiment, only the 
affected sequence table fragments, group table, and data fragments are replaced. 

Typical modifications to an object may include appending to the end of the object 
or replacing portions of the object. Figure 16 illustrates the process of appending to the 
end of an object where the last sequence table fragment has sufficient entry space to 
accommodate more data fragments. 

The object's last data fragment is located in step 1610. A fragment of size k is 
selected from the remaining data to be appended (z) in step 1612. In step 1620 a block 
with sufficient storage space to accommodate the fragment is located. Steps 1612 and 
1620 are performed with the same constraints as steps 1410 and 1424 of Figure 14. 

In step 1622 the number of valid fragments in the selected block that are 
associated with the sequence table being appended to are counted. The sequence table 
entry is then written in step 1630 with a status of "allocating." The sequence table entry 
status is then changed to "entry written" in step 1632. 

The data fragment header is written in step 1634 indicating that the data fragment 
status is "allocating." The status is changed to "header written" in step 1636. Step 1640 
initiates writing the data fragment itself. 

After the data fragment has been written, the data fragment status is changed to 
"allocated" in step 1642. The data fragment status is then changed "valid" in step 1644. 

Step 1650 determines whether there is any data remaining to be appended. If so, 
steps 1612-1642 are repeated until there is no data remaining to be appended. After the 
data has been stored, the status of the new sequence table entries is changed to "valid" in 
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step 1670. The process of appending when sufficient space exists in the present sequence 
table is finished in step 1690. 

Figures 17-18 illustrate the process of replacing portions of a fragmented object 
on a one-to-one fragment basis (i.e., a fragment is replaced by only one other fragment). 
Generally, any replaced data fragments will be invalidated. Their associated sequence 
table fragments must be rewritten with the locations of the replacement data fragments. 
Similarly, the group table must be rewritten to reflect the new location of the sequence 
table fragments. 

The data fragments to be replaced and their corresponding sequence table 
fragments are located in step 1710. A block with sufficient space to store a new group 
table is located in step 1712. The new group table header is written in step 1714 with a 
status of "allocating." The status of the new group table is changed to "header written" in 
step 1716. 

Step 1720 copies the unaffected group table entries from the old group table to the 
new group table without the instance information for the sequence table fragments. The 
unaffected group table entries identify the location of the sequence table fragments that 
are not changing. When more than one sequence table fragment for the same object is 
located in the same block, the elimination of one of the sequence table fragments during 
the replacement process necessarily changes the instance information (i.e., "count") for 
all the object's subsequent sequence table fragments located in the same block. Thus step 
1722 updates the instance information for the otherwise unchanged group table entries 
identifying unchanged sequence table fragments. 

Steps 1730 through 1844 are applied to each sequence table being replaced. Step 
1730 locates a block with sufficient space for writing a new sequence table fragment for a 
selected old sequence table fragment. A new sequence table fragment header is written 
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with a status of "allocating" in step 1732. The new sequence table fragment status is 
changed to "header written" in step 1734. The entries of the old sequence table that 
identify unchanged data fragments are copied (without the instance information) to the 
new sequence table in step 1736. These entries then have their instance information 
5 updated in step 1738. The updating of the instance information for individual sequence 
table entries does not count the data fragments being replaced when computing the 
instance information for the unchanged data fragments. 

The process continues in Figure 18 by selecting one of the replacement data 
fragments in step 1810. A block with sufficient space to write one of the replacement 

10 data fragments is selected in step 1812. The data fragment header is written with a status 
of "allocating" in step 1814. The Table Number (312) that associates the data fragment 
with the new sequence table fragment is also written as part of the header in step 1814. 
The data fragment status is changed to "header written" in step 1816. 

Step 1820 initiates writing the replacement data fragment. The instance number 

15 for this fragment is then calculated in step 1822 before writing the instance information to 
the sequence table entry identifying this data fragment in step 1824. 

Step 1830 determines whether there are additional data fragments to be stored. If 
so and the selected sequence table fragment is not full (1840), the processing returns to 
step 1810 to continue replacing the data fragments associated with the selected sequence 

20 table fragment. If the sequence table fragment is full (1840), then the new sequence table 
fragment status is changed to "allocated" (1842) and the new group table is updated with 
the information for this sequence table fragment in step 1844 before returning to step 
1740 to create a new sequence table fragment. 

If there are no more data fragments to be stored, then the new sequence table 

25 fragment status is changed to "allocated" in step 1910 of Figure 19 and the new group 
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table is updated with the information for this sequence table fragment in step 1920. The 
status of all replaced data fragments, sequence table fragments, and the old group table is 
then changed to "invalid" in step 1930. The status of the new data fragments, sequence 
table fragments, and group table is then changed to "valid" in step 1940 before 
5 completing the process in step 1990. 

The embodiments of writing and modifying the data described above use a 
number of status values in order to enable recovering to a previous state in the event of a 
power loss during a write or modification operation. The status of each entry of a 
sequence table, the sequence table itself, every data fragment identified in the sequence 

10 table, and the group table are changed at specific points during the writing and modifying 
processes. The multiple status values enable determining if one of the processes was 
interrupted and at what point. If the writing or modifying process is not completed, the 
nonvolatile memory can be restored to a known state. If power loss recovery is 
unnecessary the intermediate steps need not be tracked. 

15 Eventually the nonvolatile memory will reach a pre-determined threshold 

corresponding to an amount of invalid data. In one embodiment, the threshold is based 
on the amount of invalid data in a given block. Alternatively, the threshold may be based 
on the total amount of invalid data in the nonvolatile memory. 

The space used by the invalid data can be recovered and made available for 

20 storage through a process referred to as "reclamation." Figure 20 illustrates a reclamation 
process. In one embodiment, once the amount of available space falls below a 
pre-determined threshold a reclamation operation is triggered (step 2020). Otherwise 
reclamation is not triggered as indicated in step 2022. 

In one embodiment, the reclamation process prioritizes the blocks for recovery by 

25 selecting the block(s) with the most amount of invalid data from the set of blocks that 
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contain invalid data (step 2030). All valid objects within the selected block are copied 
from the selected block to the spare block 116 in step 2032. 

When copying the valid objects, the space previously used by the invalid objects 
is compacted out so that the headers of the valid objects are contiguous and the objects 
themselves are similarly located contiguous to each other as illustrated in Figure 2. Thus 
the amount of space previously used by invalid objects (and their corresponding headers) 
is recovered resulting in an increase in the size of area 230. 

The block information structure 240 for the spare block 1 16 is updated with the 
logical block number of the selected block in step 2040. The selected block is then 
erased and becomes the new spare block to be used when reclaiming another block in step 
2042. 

In one embodiment, the reclaim process is triggered only in response to a write or 
a modify command as indicated by step 2010. Once triggered in step 2020, the 
reclamation process repeats steps 2030-2050 until there is sufficient free space to perform 
the requested operation as determined in step 2050. 

Figure 21 illustrates a flash memory system 2100. For purposes of explanation, 
the signal lines shown are used to illustrate how flash memory system 2100 handles 
power-loss. However, other signals and signal lines (not shown) may also be used to 
operate a flash memory. For example, other control signals and signal lines may be used 
for flash memory system 2100. 

Referring to Figure 21, flash memory system 2100 includes a micro-controller 
2102 coupled with a flash memory 2104, which includes a write state memory (WSM) 
2106. Micro-controller 2102 operates to control writing and reading of data to and from 
flash memory 2104. Micro-controller 2102 also operates to receive a reset signal on a 
reset in signal line 2108. Micro-controller 2102 further operates to provide a reset signal 
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on a reset out signal line 2110 and a write enable signal on a write enable signal line 21 16 
to flash memory 2104. Micro-controller 2102 also operates to provide address data on 
address bus 2114 and data on data bus 2114 to flash memory 2104. 

Flash memory 2104 includes a plurality of flash memory cells. Flash memory 
2104 operates to store data and provide data from and to micro-controller 2102. The 
write state machine (WSM) 2106 contained in flash memory 2104 operates to control 
various data modification operations for flash memory 2104. For example, WSM 2106 
can be used to store data to flash memory 2104. 

Figure 22 illustrates a timing diagram for flash memory system 2100 causing 
storage of invalid. Referring to Figure 22, the problem is illustrated when the "reset out#" 
signal of micro-controller 2102 is not synchronized to the end of the current bus cycle. In 
this case, the current bus cycle is aborted by micro-controller 2102 upon assertion of the 
asynchronous "reset in#" signal. If the aborted bus cycle is a Flash program-data bus 
cycle (i.e., a Flash program-setup in previous bus cycle), the write enable signal from 
micro-controller 2102 could be deasserted prematurely by micro-controller 2102. If this 
occurs, the data on data bus 2114 may not yet be valid. 

This invalid data could be latched into the Flash internal data holding register (not 
shown) of flash memory 2104. The WSM 2106 for flash memory 2104 could then 
commence with the programming sequence prior to receiving the reset signal from micro- 
controller 2102. If this race condition between the reset out signal and the write-enable 
signal results in a programming pulse prior to aborting the WSM, the flash memory 2104 
would then be programmed with invalid data. That is, if deassertion of write-enable 
occurs prior to flash memory 2104 detecting a reset, the WSM 2106 would start a 
programming cycle on invalid data. 
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Typically, the resulting invalid data of the above case would be discarded by 
evaluating the states tracked in a power-loss recovery (PLR) status field. However, if the 
PLR status field itself was corrupted, the power-loss recovery code in the PLR status field 
would be invalid or unreliable. 

Figure 23 illustrates a new data header 2300 having duplicate power-loss status 
fields 3212 and 2316, which are used to eliminate the power-loss recovery problem as 
discussed in Figure 22. New data header 2300 can be used for blocks of data stored in 
flash memory 2104. New data header 2300 includes an identifier field 2302, 
table_number field 2306, g_unit_size field 2304, g_unit_offset_bottom field 2308, PLR 
status field 2310, PLR status 2 filed 2312, type_attribute field 2314, and reserved field 
2316. The duplicate status field PLR status 2 is not to be written in the same bus cycle as 
the PLR status in PLR status field 2310. 

Figure 24 illustrates a method 2400 for duplicating power-loss status fields for a 
data header. For example, method 2400 can be used to create new data header 2300 in 
which PLR status fields are duplicated to eliminate the power-loss recovery problem as 
explained in Figure 22. For purposes of explanation, method 2400 begins at step 2402. 

At step 2402, power-loss (PLR) states are proposed for HDR/Data validation. At 
step 2404, a first PLR status for PLR status field 2310 is allocated. A second PLR status 
for PLR status 2 field 2312 is allocated. At step 2408, the HDR is written. At step 241 1, 
PLR status for PLR status field 2310 is set to valid HDR. At step 2410, PLR status 2 for 
PLR status 2 field 2312 is set to valid HDR. 

At step 2412, data is written to flash memory 2104. At step 2414, the first PLR 
status for PLR status field 2310 is allocated. At step 2416, the second PLR status for 
PLR status 2 field 2312 is allocated. At step 2418, the old HDR is marked "invalid." 
Then, at step 2420, the first PLR status for PLR status field 2310 is allocated. At step 
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2416, the second PLR status for PLR status 2 field 2312 is allocated. At step 2418, the 
old HDR is marked "invalid." Then, at step 2420, the first PLR status is set to "valid." 
At step 2422 the PLR status 2 is set to "valid." At step 2424, the process for setting PLR 
states ends. 

5 Thus, by duplicating the PLR status fields, the above method can be used to 

eliminate problems arising in power-loss recovery. At each PLR state update, the 
duplicated status would be written with the same value as the main status, but in a 
subsequent bus cycle. That is, because a flash memory cannot program from 0 to 1, 
regardless of the invalid data latched, the status field with most of its bits in a "1" state 

10 would constitute a valid status. As such, the PLR code used would be the one with the 
most "1" states and the other PLR status would be discarded. 

If, however, power-loss were to occur between the two status updates, then the 
PLR code would effectively recover the data one state earlier. However, such an event is 
much more acceptable than not being able to recover at all. The above method provides 

15 advantages over other methods for recovering status fields. For example, using an Error- 
Correction Code (ECC) such as a Hamming code, the recovery ECC process would 
require additional software overhead to generate the ECC codes and detection would not 
be guaranteed if more than 2 bits were improperly programmed to 0 in the status field. 

Furthermore, the above method and new data header can be used in existing flash 

20 data integrator (FDI) software product so that the power-loss recovery code is made more 
robust. The FDI can be used in cellular phone applications and similar applications that 
have power-loss recovery requirements. 

In the foregoing specification, the invention is described with reference to specific 
exemplary embodiments thereof. It will, however, be evident that various modifications 

25 and changes may be made thereto without departing from the broader spirit and scope of 
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the invention as set forth in the appended claims. The specification and drawings are, 
accordingly, to be regarded in an illustrative sense rather than a restrictive sense. 
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CLAIMS 



What is claimed is: 



1 L A method of storing objects in a nonvolatile memory comprising: 

2 allocating space within a block erasable nonvolatile memory for an object, 

3 wherein the allocated space is within a single block; 

4 storing a first instance of the object within the allocated space; and 

5 storing a superseding second instance of the object within the allocated space 

6 without erasing any of the allocated space, wherein each instance of the object is a fixed 

7 size, wherein the allocated space exceeds a multiple of the fixed size. 

1 2. The method of claim 1 , further comprising: 

2 updating status information within the allocated space to reflect that the second 

3 instance supersedes the first instance. 

1 3. The method of claim 1 , further comprising: 

2 storing a header within a same block as the allocated space, wherein the header 

3 identifies a location of the allocated space within the same block. 

1 4. The method of claim 1, wherein the nonvolatile memory is a flash electrically 

2 erasable programmable read only memory. 

1 5. A method comprising: 

2 receiving data for storage in a nonvolatile memory comprising a plurality of 

3 blocks; 
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4 selecting a storage structure for the data according to a size (z) of the data, a 

5 minimum number of instances (m), a maximum single instance size C?*g), and an 

6 allocation granularity (g); 

7 storing the data in the selected structure within the nonvolatile memory. 

1 6. The method of claim 5, wherein selecting the storage structure includes selecting a 

2 multiple instance structure, if z < — overhead ^ wherein the over jj ea< i j s an amount 

m 

3 of space required as overhead for m instances within the multiple instance structure. 

1 7. The method of claim 5, wherein selecting the storage structure further includes 

2 selecting a single instance structure, if z • s*g for s expressed as a number of granular 

3 units. 

1 8. The method of claim 5, wherein selecting the storage structure further includes 

2 fragmenting the data into a plurality of data fragments for storage, if z > s*g for s 

3 expressed as a number of granular units. 

1 9. The method of claim 8, wherein storing the data includes: 

2 storing the data fragments using a sequence table indicative of an order and a location of 

3 the data fragments, if a sequence table size does not exceed a maximum sequence table 

4 size; and 

5 storing a header for each data fragment and the sequence table, wherein the header 

6 is located in a same block as its associated data fragment and sequence table, wherein 

7 within a given block the headers are stored contiguously proceeding from a first end to a 
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8 second end of the given block, wherein objects identified by the headers are stored 

9 contiguously proceeding from the second end to a first end of the given block. 

1 10. The method of claim 8, wherein storing the data further includes: 

2 storing the data fragments using sequence table fragments and a group table, if a 

3 sequence table size exceeds the maximum sequence table size, wherein the sequence 

4 table fragments are indicative of an order and a location of the data fragments, wherein 

5 the group table is indicative of an order and a location of the sequence table fragments; 

6 and 

7 storing a header for each data fragment, sequence table fragment, and group table, 

8 wherein the header is located in a same block as its associated data fragment, sequence 

9 table fragment, and group table, wherein within a given block the headers are stored 

10 contiguously proceeding from a first end to a second end of the given block, wherein 

11 objects identified by the headers are stored contiguously proceeding from the second end 

12 to a first end of the given block. 

1 11. A method for a memory device comprising: 

2 duplicating a power-loss recovery (PLR) status field such that the duplicated PLR 

3 status field is used if the PLR status field is invalid. 

1 12. The method of claim 1 1, wherein duplicating the PLR status field includes: 

2 writing a same value in the PLR status field in the duplicated PLR status field 
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1 13. The method of claim 12, wherein writing the same value includes writing the 

2 same value in the PLR status filed in the duplicated PLR status field in a subsequent bus 

3 cycle. 

1 14. The method of claim 1 1 , further comprising: 

2 determining which of the PLR status field or the duplicated PLR status field 

3 contains a greater amount of "1" bits for use in a power-loss recovery operation. 

1 15. The method of claim 1 1 , wherein duplicating the power-loss recovery (PLR) 

2 status field includes duplicating the power-loss recovery (PLR) status field a flash 

3 memory device. 
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ABSTRACT OF THE DISCLOSURE 

A power-loss recovery method is disclosed in which a power-loss recovery (PLR) 
status field is duplicated such that the duplicated PLR status field is used if the PLR 
status field is invalid. By duplicating the PLR status field, reliability of data stored in a 
memory device such as a flash memory sensitive to power-loss can be increased. 
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Prior Foreign Application(s) 



Priority 
Claimed 



(Number) 


(Country) 


(Day/Month/Year Filed) 


YeT 


No" 


(Number) 


(Country) 


(Day/Month/Year Filed) 


YeT 


No" 


(Number) 


(Country) 


(Day/Month/Year Filed) 


YeT 


No" 



I hereby claim the benefit under title 35, United States Code, Section 1 19(e) of any United States 
provisional application(s) listed below 



(Application Number) Filing Date 



(Application Number) Filing Date 



I hereby claim the benefit under Title 35, United States Code, Section 120 of any United States 
application(s) listed below and, insofar as the subject matter of each of the claims of this application 
is not disclosed in the prior United States application in the manner provided by the first paragraph 
of Title 35, United States Code, Section 1 12, 1 acknowledge the duty to disclose all information 
known to me to be material to patentability as defined in Title 37, Code of Federal Regulations, 
Section 156 which became available between the filing date of the prior application and the national 
or PCT international filing date of this application: 



(Application Number) Filing Date (Status - patented, 

pending, abandoned) 



(Application Number) 



Filing Date 



(Status - patented, 

pending, abandoned) 



I hereby appoint Farzad E. Amini, Reg. No. P42,261; Aloysius T. C. AuYeung, Reg. No. 35,432; William 
Thomas Babbitt, Reg. No. 39,591; Jordan Michael Becker, Reg. No. 39,602; Bradley J. Bereznak, Reg. 
No. 33,474; Michael A. Bernadicou, Reg. No. 35,934; Roger W. Blakely, Jr., Reg. No. 25,831; Gregory D. 
Caldwell, Reg. No. 39,926; Kent M. Chen, Reg. No. 39,630; Lawrence M. Cho, Reg. No. 39,942; Thomas 
M. Coester, Reg. No. 39,637; Roland B. Cortes, Reg. No. 39,152; Barbara Bokanov Courtney, Reg, No. 
P42,442; William Donald Davis, Reg. No. 38,428; Michael Anthony DeSanctis, Reg. No. 39,957; Daniel M. 
De Vos, Reg. No. 37,813; Tarek N. Fahmi, Reg. No. 41,402; Richard Leon Gregory, Jr., P42,607; James 
Y. Go, Reg. No. 40,621; Sharmini Nathan Green, Reg. No. 41,410; David R. Halvorson, Reg. No. 33,395; 
Thomas A. Hassing, Reg. No. 36,159; Eric Ho, Reg. No. 39,711; George W Hoover II, Reg. No. 32,992; 
EricS. Hyman, Reg. No. 30,139; Dag H. Johansen, Reg. No. 36,172; Stephen L. King, Reg. No. 19,180; 
Michael J. Mallie, Reg. No. 36,591; Paul A. Mendonsa, Reg. No. P42,879; Darren J. Milliken, P42,004; 
Thinh V. Nguyen, P42,034; Kimberley G. Nobles, Reg. No. 38,255; Michael A. Proksch, Reg. No. 
P43,021; Ronald W. Reagin, Reg. No. 20,340; Babak Redjaian, P42,096; James H. Salter, Reg. No. 
35,668; William W. Schaal, Reg. No. 39,018; James C. Scheller, Reg. No. 31,195; Anand Sethuraman, 
Reg. No. P43,351; Charles E. Shemwell, Reg. No. 40,171; Maria McCormack Sobrino, Reg. No. 31,639; 
Stanley W. Sokoloff, Reg. No. 25,128; Allan T. Sponseller, Reg. No. 38,318; Steven R. Sponseller, Reg. 
No. 39,384; Geoffrey T. Staniford, P43,151; Judith A. Szepesi, Reg. No. 39,393; Edwin H. Taylor, Reg. 
No. 25,129; George G. C. Tseng, Reg. No. 41,355; Lester J. Vincent, Reg. No. 31,460; John 
Patrick Ward, Reg. No. 40,216; Ben J. Yorks, Reg. No. 33,609; and Norman Zafman, Reg. No. 26,250; r 
my attorneys; and Robert Andrew Diehl, Reg. No. 40,992; and Edwin A. Sloane, Reg. No. 34,728; my " 
patent agents, of BLAKELY, SOKOLOFF, TAYLOR & ZAFMAN LLP, with offices located at 12400 
Wilshire Boulevard, 7th Floor, Los Angeles, California 90025, telephone (310) 207-3800, and Alan K. 
Aldous, Reg. No. 31,905; Robert D. Anderson, Reg. No. 33,826; Joseph R. Bond, Reg. No, 36,458; 
Richard C. Calderwood, Reg. No. 35,468; Cynthia Thomas Faatz, Reg No. 39,973; Sean Fitzgerald, Reg. 
No. 32,027; Seth Z. Kalson, Reg. No. 40,670; David J. Kaplan, Reg. No. 41,105; Leo V. Novakoski, Reg. 
No. 37,198; Naomi Obinata, Reg. No. 39,320; Thomas C. Reynolds, Reg. No. 32,488; Steven P. Skabrat, 
Reg. No. 36,279; Howard A. Skaist, Reg. No. 36,008; Steven C. Stewart, Reg. No. 33,555; Raymond J. 
Werner, Reg. No. 34,752; and Charles K. Young, Reg. No. 39,435; my patent attorneys, of INTEL 
CORPORATION; and James R. Thein, Reg. No. 31,710, my patent attorney; with full power of substitution 
and revocation, to prosecute this application and to transact all business in the Patent and Trademark 
Office connected herewith. 

Send correspondence to William D. Davis BLAKELY, SOKOLOFF, 

(Name of Attorney or Agent) 
TAYLOR & ZAFMAN LLP, 12400 Wilshire Boulevard, 7th Floor, Los Angeles, California 90025 and 

direct telephone calls to William D. Davis , (503) 684-6200. 

(Name of Attorney or Agent) 

I hereby declare that all statements made herein of my own knowledge are true and that all 
statements made on information and belief are believed to be true; and further that these statements 
were made with the knowledge that willful false statements and the like so made are punishable by 
fine or imprisonment, or both, under Section 1001 of Title 18 of the United States Code and that 
such willful false statements may jeopardize the validity of the application or any patent issued 
thereon. 



Full Name of Sole/First Inventor Deborah L See 

Inventor's Signature V^U^ , ^ ^ — ^ Date (o/go/^f' 

Residence Placerville. California Citizenship United States 

(City, State) (Country) 

Post Office Address 5880 October Hill Road 

Placerville. California 95667 

Full Name of Second/Joint Inventor Robert N. Hasbun 



Inventor's Signature Date C*/'/^/' ^ 

Residence Placerville. California Citizenship United States 

(City, State) (Country) 

Post Office Address 2460 Mortura Circle 

Placerville. California 95667 



Full Name of Third/Joint Inventor Jeffrey A. Dunlap 
Inventor's Signature 




Q_ Ot^UajO Date 7/6/7? 



Residence -Wftom. California Citizenship United States 

(City, State) (Country) 

Post Office Address ^000- P uii iy Cilv Kuad. I W8 I -2 J Vj^er^jJax/ 

Full Name of Fourth/Joint Inventor Phillip J. del Pozo. Ill 



Inventor's Sign3 jk ^ Date / 2-~L~/ f & 

Residence -FoteemrCalifomia Citizenship United States 

(City, State) (Country) 

Post Office Address Jc^7"7 5^n*£/4 La*.^ 

F u l i j o m. Cctliru i n i a 9563 6- f \ tW^Ao M'SK . T A ?C 76^ 



Full Name of Fifth/Joint Inventor 



Inventor's Signature Date 

Residence Citizenship . 



(City, State) (Country) 
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